#plotting format
plotformat = theme(plot.title = element_text(face="bold",size = 17,hjust = 0.5),axis.title = element_text(face = "bold",size =15), axis.text.x = element_text(size=12), axis.title.y=element_text(size=14))+theme_bw()

theme_facet = function(base_size = 14, base_family = "Helvetica") {
  # Starts with theme_grey and then modify some parts
  theme_bw(base_size = base_size, base_family = base_family) %+replace%
    theme(
      strip.background = element_blank(),
      strip.text.x = element_text(size = 10),
      strip.text.y = element_text(size = 10),
      axis.text.x = element_blank(),
      axis.text.y = element_text(size=12,hjust=1),
      axis.ticks =  element_blank(), #element_line(colour = "black"), 
      axis.title.x= element_text(size=12),
      axis.title.y= element_text(size=12,angle=90),
      panel.background = element_blank(), 
      panel.border =element_blank(), 
      panel.grid.minor = element_blank(), 
      panel.spacing = unit(0.5, "lines"), 
      plot.background = element_blank(), 
      plot.margin = unit(c(0.3,  0.3, 0.3, 0.3), "lines"),
      axis.line.x = element_line(color="black", size = 0.5),
      axis.line.y = element_line(color="black", size = 0.5)
    )
}
#color
Features = c('#deebf7','#9ecae1','#6baed6','#4292c6','#08519c','#08306b',
             '#fee6ce','#fdae6b','#fd8d3c','#f16913','#a63603','#7f2704',
             '#f0f0f0','#bdbdbd','#969696','#737373','#252525','#000000',
             '#efedf5','#bcbddc','#9e9ac8','#807dba','#54278f','#3f007d')
dataPath = '/Volumes/Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/';

SameDifferent_fnames = list.files(path = dataPath,pattern = "SameDifferent")
Demo_fnames = list.files(path = dataPath,pattern = "demographics")

Load data

##specify variables
#for behavior information
completeFnames =list()
totalData = data.frame()
ic = 1;

#for demographic information
gender = data.frame()
age = data.frame()
ethnicity= data.frame()
race = data.frame()
subID = data.frame()

##
for (ifiles in 1:length(SameDifferent_fnames)){
  tempFile = read.table(paste0(dataPath,SameDifferent_fnames[ifiles]),header = F)
  Trials = unlist(strsplit(as.character(tempFile$V1), ";"))
  
  if (length(Trials)>10){
    keyNum = data.frame()
    accuracy = data.frame()
    feature_index = data.frame()
    RT = data.frame()
    Fir_img = data.frame()
    Sec_img = data.frame()
    for (i in 1:length(Trials)){
      temp = unlist(strsplit(Trials[i],","));
      keyNum = rbind(keyNum,as.numeric(temp[2]))
      accuracy = rbind(accuracy,as.numeric(temp[4]))
      RT = rbind(RT,as.numeric(temp[5]))
      feature_index = rbind(feature_index,as.numeric(temp[6]))
      Fir_img = rbind(Fir_img,as.numeric(temp[7]))
      Sec_img = rbind(Sec_img,as.numeric(temp[8]))
    }
    data = cbind(keyNum,accuracy,RT, feature_index,Fir_img,Sec_img)
    colnames(data) = c("keys","accuracy", "rt","feature_index", "Fimg","Simg")
    data = data[-1,]
    data$subID = ifiles;
    data$trialNum = 1:dim(data)[1];
    
    totalData = rbind(totalData,data)

    #subject ID for completing the tasks
    for (ifilesDe in 1:length(Demo_fnames)){
      if (unlist(strsplit(SameDifferent_fnames[ifiles],"SameDifferent"))[2]==unlist(strsplit(Demo_fnames[ifilesDe],"demographics"))[2]){
        tempDemoFile = read.table(paste0(dataPath,Demo_fnames[ifilesDe]),header = F)
        Demo_info = unlist(strsplit(as.character(tempDemoFile$V1), ";"))
        gender[ic,1] = unlist(Demo_info[1])
        age[ic,1]=unlist(Demo_info[2])
        ethnicity[ic,1]=unlist(Demo_info[3])
        race[ic,1]=unlist(Demo_info[4])
        subID[ic,1]=unlist(ifiles)
        }
    completeFnames[ic] =unlist(strsplit(SameDifferent_fnames[ifiles],"SameDifferent"))[2]}
    ic = ic+1;
  }else{
  }
}
## Warning in read.table(paste0(dataPath, SameDifferent_fnames[ifiles]),
## header = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## SameDifferent30BXRYBRP4XIPNKACEMW2TIYJ5KWHO.txt'
## Warning in read.table(paste0(dataPath, Demo_fnames[ifilesDe]), header
## = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## demographics30BXRYBRP4XIPNKACEMW2TIYJ5KWHO.txt'
## Warning in read.table(paste0(dataPath, SameDifferent_fnames[ifiles]),
## header = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## SameDifferent31EUONYN2V3F2F6SQHCQ00WLOIKOVI.txt'
## Warning in read.table(paste0(dataPath, Demo_fnames[ifilesDe]), header
## = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## demographics31EUONYN2V3F2F6SQHCQ00WLOIKOVI.txt'
## Warning in read.table(paste0(dataPath, SameDifferent_fnames[ifiles]),
## header = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## SameDifferent32UTUBMZ7GWVJLHJMC74UGWMHO7VB1.txt'
## Warning in read.table(paste0(dataPath, Demo_fnames[ifilesDe]), header
## = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## demographics32UTUBMZ7GWVJLHJMC74UGWMHO7VB1.txt'
## Warning in read.table(paste0(dataPath, SameDifferent_fnames[ifiles]),
## header = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## SameDifferent336KAV9KYQSIZ2CS8U1D0MXC5UQY2V.txt'
## Warning in read.table(paste0(dataPath, Demo_fnames[ifilesDe]), header
## = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## demographics336KAV9KYQSIZ2CS8U1D0MXC5UQY2V.txt'
## Warning in read.table(paste0(dataPath, SameDifferent_fnames[ifiles]),
## header = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## SameDifferent339ANSOTR52RQI1DTILEEUPIWBSKIB.txt'
## Warning in read.table(paste0(dataPath, Demo_fnames[ifilesDe]), header
## = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## demographics339ANSOTR52RQI1DTILEEUPIWBSKIB.txt'
## Warning in read.table(paste0(dataPath, SameDifferent_fnames[ifiles]),
## header = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## SameDifferent34PGFRQONOBEGTF00EPHE6YDWXDJW5.txt'
## Warning in read.table(paste0(dataPath, Demo_fnames[ifilesDe]), header
## = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## demographics34PGFRQONOBEGTF00EPHE6YDWXDJW5.txt'
## Warning in read.table(paste0(dataPath, SameDifferent_fnames[ifiles]),
## header = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## SameDifferent36WLNQG78ZAEHAVXRMIUUC80H1REBH.txt'
## Warning in read.table(paste0(dataPath, Demo_fnames[ifilesDe]), header
## = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## demographics36WLNQG78ZAEHAVXRMIUUC80H1REBH.txt'
## Warning in read.table(paste0(dataPath, SameDifferent_fnames[ifiles]),
## header = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## SameDifferent37UEWGM5HT82DGIABV95N7UA93N1R8.txt'
## Warning in read.table(paste0(dataPath, Demo_fnames[ifilesDe]), header
## = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## demographics37UEWGM5HT82DGIABV95N7UA93N1R8.txt'
## Warning in read.table(paste0(dataPath, SameDifferent_fnames[ifiles]),
## header = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## SameDifferent37XITHEISW9M0JS8RSYP43D1EYSRCZ.txt'
## Warning in read.table(paste0(dataPath, Demo_fnames[ifilesDe]), header
## = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## demographics37XITHEISW9M0JS8RSYP43D1EYSRCZ.txt'
## Warning in read.table(paste0(dataPath, SameDifferent_fnames[ifiles]),
## header = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## SameDifferent388U7OUMF7126RXSFC5592B059S0RC.txt'
## Warning in read.table(paste0(dataPath, Demo_fnames[ifilesDe]), header
## = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## demographics388U7OUMF7126RXSFC5592B059S0RC.txt'
## Warning in read.table(paste0(dataPath, SameDifferent_fnames[ifiles]),
## header = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## SameDifferent39OWYR0EPKR20WO4WPGKK5R1EY8YFS.txt'
## Warning in read.table(paste0(dataPath, Demo_fnames[ifilesDe]), header
## = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## demographics39OWYR0EPKR20WO4WPGKK5R1EY8YFS.txt'
## Warning in read.table(paste0(dataPath, SameDifferent_fnames[ifiles]),
## header = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## SameDifferent3A4TN5196KI9BPE5VNMVQZBVRQKCHF.txt'
## Warning in read.table(paste0(dataPath, Demo_fnames[ifilesDe]), header
## = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## demographics3A4TN5196KI9BPE5VNMVQZBVRQKCHF.txt'
## Warning in read.table(paste0(dataPath, SameDifferent_fnames[ifiles]),
## header = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## SameDifferent3AAJC4I4FGSIAOK5B19ODASVDZOJZ2.txt'
## Warning in read.table(paste0(dataPath, Demo_fnames[ifilesDe]), header
## = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## demographics3AAJC4I4FGSIAOK5B19ODASVDZOJZ2.txt'
## Warning in read.table(paste0(dataPath, SameDifferent_fnames[ifiles]),
## header = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## SameDifferent3AWETUDC92SMFD0ZTJOO19DV0OSIZQ.txt'
## Warning in read.table(paste0(dataPath, Demo_fnames[ifilesDe]), header
## = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## demographics3AWETUDC92SMFD0ZTJOO19DV0OSIZQ.txt'
## Warning in read.table(paste0(dataPath, SameDifferent_fnames[ifiles]),
## header = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## SameDifferent3BF51CHDTVAPHXJPJ7TBVY9UIP6H0M.txt'
## Warning in read.table(paste0(dataPath, Demo_fnames[ifilesDe]), header
## = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## demographics3BF51CHDTVAPHXJPJ7TBVY9UIP6H0M.txt'
## Warning in read.table(paste0(dataPath, SameDifferent_fnames[ifiles]),
## header = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## SameDifferent3HL8HNGX451NZVGWODO4LOYA535F9U.txt'
## Warning in read.table(paste0(dataPath, Demo_fnames[ifilesDe]), header
## = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## demographics3HL8HNGX451NZVGWODO4LOYA535F9U.txt'
## Warning in read.table(paste0(dataPath, SameDifferent_fnames[ifiles]),
## header = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## SameDifferent3HYA4D452RJCZBVX349PB1QWYL02F5.txt'
## Warning in read.table(paste0(dataPath, Demo_fnames[ifilesDe]), header
## = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## demographics3HYA4D452RJCZBVX349PB1QWYL02F5.txt'
## Warning in read.table(paste0(dataPath, SameDifferent_fnames[ifiles]),
## header = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## SameDifferent3I0BTBYZAXLB3S9ET7XZHY4X7YY0Y8.txt'
## Warning in read.table(paste0(dataPath, Demo_fnames[ifilesDe]), header
## = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## demographics3I0BTBYZAXLB3S9ET7XZHY4X7YY0Y8.txt'
## Warning in read.table(paste0(dataPath, SameDifferent_fnames[ifiles]),
## header = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## SameDifferent3IGI0VL647K2UAXJOQQZQJ282JXONO.txt'
## Warning in read.table(paste0(dataPath, Demo_fnames[ifilesDe]), header
## = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## demographics3IGI0VL647K2UAXJOQQZQJ282JXONO.txt'
## Warning in read.table(paste0(dataPath, SameDifferent_fnames[ifiles]),
## header = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## SameDifferent3IX2EGZR7BJ98XYE1KFBR7QW4I6JRA.txt'
## Warning in read.table(paste0(dataPath, Demo_fnames[ifilesDe]), header
## = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## demographics3IX2EGZR7BJ98XYE1KFBR7QW4I6JRA.txt'
## Warning in read.table(paste0(dataPath, SameDifferent_fnames[ifiles]),
## header = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## SameDifferent3KJYX6QCM9B114FVA4KLS4FZPOBJVV.txt'
## Warning in read.table(paste0(dataPath, Demo_fnames[ifilesDe]), header
## = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## demographics3KJYX6QCM9B114FVA4KLS4FZPOBJVV.txt'
## Warning in read.table(paste0(dataPath, SameDifferent_fnames[ifiles]),
## header = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## SameDifferent3LUY3GC63Z0VCPHXNJMPJML8C5B7PS.txt'
## Warning in read.table(paste0(dataPath, Demo_fnames[ifilesDe]), header
## = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## demographics3LUY3GC63Z0VCPHXNJMPJML8C5B7PS.txt'
## Warning in read.table(paste0(dataPath, SameDifferent_fnames[ifiles]),
## header = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## SameDifferent3OWEPKL089CV945K749XFXGDCNYN7U.txt'
## Warning in read.table(paste0(dataPath, Demo_fnames[ifilesDe]), header
## = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## demographics3OWEPKL089CV945K749XFXGDCNYN7U.txt'
## Warning in read.table(paste0(dataPath, SameDifferent_fnames[ifiles]),
## header = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## SameDifferent3OXV7EAXLEQ510Y56BKQ05IBCC863H.txt'
## Warning in read.table(paste0(dataPath, Demo_fnames[ifilesDe]), header
## = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## demographics3OXV7EAXLEQ510Y56BKQ05IBCC863H.txt'
## Warning in read.table(paste0(dataPath, SameDifferent_fnames[ifiles]),
## header = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## SameDifferent3OXV7EAXLEQ510Y56BKQ05IBCY336H.txt'
## Warning in read.table(paste0(dataPath, Demo_fnames[ifilesDe]), header
## = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## demographics3OXV7EAXLEQ510Y56BKQ05IBCY336H.txt'
## Warning in read.table(paste0(dataPath, SameDifferent_fnames[ifiles]),
## header = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## SameDifferent3PWWM24LHSY3KWLAVQ3J199ACFS28Q.txt'
## Warning in read.table(paste0(dataPath, Demo_fnames[ifilesDe]), header
## = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## demographics3PWWM24LHSY3KWLAVQ3J199ACFS28Q.txt'
## Warning in read.table(paste0(dataPath, SameDifferent_fnames[ifiles]),
## header = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## SameDifferent3QUO65DNQUOFP0HSLR2L4EU2ACTOUD.txt'
## Warning in read.table(paste0(dataPath, Demo_fnames[ifilesDe]), header
## = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## demographics3QUO65DNQUOFP0HSLR2L4EU2ACTOUD.txt'
## Warning in read.table(paste0(dataPath, SameDifferent_fnames[ifiles]),
## header = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## SameDifferent3SLE99ER0NDCS5MTN9W7FM9I5Y6BZ8.txt'
## Warning in read.table(paste0(dataPath, Demo_fnames[ifilesDe]), header
## = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## demographics3SLE99ER0NDCS5MTN9W7FM9I5Y6BZ8.txt'
## Warning in read.table(paste0(dataPath, SameDifferent_fnames[ifiles]),
## header = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## SameDifferent3V5Q80FXIXRHJZF4J98NAS1ZWT6234.txt'
## Warning in read.table(paste0(dataPath, Demo_fnames[ifilesDe]), header
## = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## demographics3V5Q80FXIXRHJZF4J98NAS1ZWT6234.txt'
## Warning in read.table(paste0(dataPath, SameDifferent_fnames[ifiles]),
## header = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## SameDifferent3VSOLARPKB9SJJ034IN2KF9D2CB39I.txt'
## Warning in read.table(paste0(dataPath, Demo_fnames[ifilesDe]), header
## = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## demographics3VSOLARPKB9SJJ034IN2KF9D2CB39I.txt'
## Warning in read.table(paste0(dataPath, SameDifferent_fnames[ifiles]),
## header = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## SameDifferent3XLBSAQ9Z4CPQTJ3ASKRAKNMM4GZ73.txt'
## Warning in read.table(paste0(dataPath, Demo_fnames[ifilesDe]), header
## = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## demographics3XLBSAQ9Z4CPQTJ3ASKRAKNMM4GZ73.txt'
## Warning in read.table(paste0(dataPath, SameDifferent_fnames[ifiles]),
## header = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## SameDifferent3Y54SXRO1LLV2SM0H8OKYO0P9PDUTI.txt'
## Warning in read.table(paste0(dataPath, Demo_fnames[ifilesDe]), header
## = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## demographics3Y54SXRO1LLV2SM0H8OKYO0P9PDUTI.txt'
## Warning in read.table(paste0(dataPath, SameDifferent_fnames[ifiles]),
## header = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## SameDifferent3YDTZAI2WXGVCAGC0JDSFEJ0INF14Y.txt'
## Warning in read.table(paste0(dataPath, Demo_fnames[ifilesDe]), header
## = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## demographics3YDTZAI2WXGVCAGC0JDSFEJ0INF14Y.txt'
## Warning in read.table(paste0(dataPath, SameDifferent_fnames[ifiles]),
## header = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## SameDifferent3Z2R0DQ0JHEKTXV18TPJTJ5WNMF2EM.txt'
## Warning in read.table(paste0(dataPath, Demo_fnames[ifilesDe]), header
## = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## demographics3Z2R0DQ0JHEKTXV18TPJTJ5WNMF2EM.txt'
## Warning in read.table(paste0(dataPath, SameDifferent_fnames[ifiles]),
## header = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## SameDifferent3Z4AIRP3C6DMAC4MKUFXCPGYBIWX1L.txt'
## Warning in read.table(paste0(dataPath, Demo_fnames[ifilesDe]), header
## = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## demographics3Z4AIRP3C6DMAC4MKUFXCPGYBIWX1L.txt'
## Warning in read.table(paste0(dataPath, SameDifferent_fnames[ifiles]),
## header = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## SameDifferent3ZQIG0FLQEGN7OFUH330HU97ROOWVF.txt'
## Warning in read.table(paste0(dataPath, Demo_fnames[ifilesDe]), header
## = F): incomplete final line found by readTableHeader on '/Volumes/
## Macintosh HD/Users/Pam_sf_wang/Documents/AMTdata/Calibration_NewDesign_005/
## demographics3ZQIG0FLQEGN7OFUH330HU97ROOWVF.txt'
demographic_information = cbind(gender,age,ethnicity,race,subID)
colnames(demographic_information) = c("Gender","Age","Ethnicity","Race","SubID")
demographic_information$Age = as.numeric(demographic_information$Age)

Identify and remove outliers

summarize = dplyr::summarize
#check basic performance -- remove non-responding subjects
temp = totalData %>% group_by(subID) %>% summarize(num_noresponses= sum(keys==-1), trialNum = length(subID))
sprintf("total trial number: %i; Number of subjects %i",temp$trialNum[1],dim(temp)[1])
## [1] "total trial number: 84; Number of subjects 36"
temp
## # A tibble: 36 x 3
##    subID num_noresponses trialNum
##    <int>           <int>    <int>
##  1     1               0       84
##  2     2               3       84
##  3     3               0       84
##  4     4               0       84
##  5     5              10       84
##  6     6               0       84
##  7     7               5       84
##  8     8               9       84
##  9     9               6       84
## 10    10               4       84
## # ... with 26 more rows
ggplot(temp, aes( y= num_noresponses, x= subID))+
  geom_point()+
  geom_hline(yintercept=42, linetype="dashed", color = "red", size=0.5)+
  labs(title="No responses", x ="subjuect ID", y = "number of no responses")+
  plotformat

#check feature number
tempFeature = totalData %>% group_by(subID) %>%summarize(feature = feature_index[1])
sprintf("Feature 1: %i; Feature 2: %i; Feature 3: %i",sum(tempFeature$feature==1),sum(tempFeature$feature==2),sum(tempFeature$feature==3))
## [1] "Feature 1: 10; Feature 2: 14; Feature 3: 12"
#no response subjects
removeSub = temp$subID[temp$num_noresponses>42]
totalData = totalData%>%filter(!subID %in% removeSub)
demographic_information = demographic_information%>%filter(!SubID %in%removeSub)

sprintf("remove subjects %i",length(removeSub))
## [1] "remove subjects 0"

Demographic information

genderCount = table(demographic_information$Gender)
EthnicityCount = table(demographic_information$Ethnicity)
RaceCount = table(demographic_information$Race)
genderCount
## 
##  F  M 
## 15 21
EthnicityCount
## 
##  HL NHL 
##   3  33
RaceCount
## 
##  A AA  M  W 
##  5  1  2 28
summary(demographic_information$Age)
##    Min. 1st Qu.  Median    Mean 3rd Qu.    Max.    NA's 
##   25.00   27.50   30.00   33.31   35.50   55.00       1
ggplot(demographic_information, aes(demographic_information$Age)) + 
  geom_histogram()+
  geom_vline(xintercept=median(demographic_information$Age), linetype="dashed", color = "red", size=0.5)+
  #geom_vline(xintercept=mean(demographic_information$Age), linetype="dashed", color = "blue", size=0.5)+
  labs(title = "Age Distribution",x = "age", y = "counts")+
  plotformat
## `stat_bin()` using `bins = 30`. Pick better value with `binwidth`.
## Warning: Removed 1 rows containing non-finite values (stat_bin).
## Warning: Removed 1 rows containing missing values (geom_vline).

Restrict age

#select right age
remainSub = demographic_information$SubID[demographic_information$Age<35]
demographic_information_remain = filter(demographic_information,SubID%in%remainSub)

summary(demographic_information_remain$Age)
##    Min. 1st Qu.  Median    Mean 3rd Qu.    Max. 
##   25.00   27.00   29.00   28.68   31.00   34.00
ggplot(demographic_information_remain, aes(Age)) + 
  geom_histogram()+
  geom_vline(xintercept=median(demographic_information_remain$Age), linetype="dashed", color = "red", size=0.5)+
  #geom_vline(xintercept=mean(demographic_information$Age), linetype="dashed", color = "blue", size=0.5)+
  labs(title = "Age Distribution",x = "age", y = "counts")+
  plotformat
## `stat_bin()` using `bins = 30`. Pick better value with `binwidth`.

genderCount = table(demographic_information_remain$Gender)
EthnicityCount = table(demographic_information_remain$Ethnicity)
RaceCount = table(demographic_information_remain$Race)
genderCount
## 
##  F  M 
## 10 15
EthnicityCount
## 
##  HL NHL 
##   1  24
RaceCount
## 
##  A AA  M  W 
##  4  1  2 18
totalData = totalData %>%filter(subID %in%remainSub)

temp = totalData %>% group_by(subID) %>% summarize(num_noresponses= sum(keys==-1), trialNum = length(subID))
sprintf("total trial number: %i; Number of subjects %i",temp$trialNum[1],dim(temp)[1])
## [1] "total trial number: 84; Number of subjects 25"
temp
## # A tibble: 25 x 3
##    subID num_noresponses trialNum
##    <int>           <int>    <int>
##  1     1               0       84
##  2     3               0       84
##  3     5              10       84
##  4     7               5       84
##  5     8               9       84
##  6    11              16       84
##  7    12               8       84
##  8    14               1       84
##  9    15               2       84
## 10    16               1       84
## # ... with 15 more rows
ggplot(temp, aes( y= num_noresponses, x= subID))+
  geom_point()+
  geom_hline(yintercept=42, linetype="dashed", color = "red", size=0.5)+
  labs(title="No responses", x ="subjuect ID", y = "number of no responses")+
  plotformat

#check feature number
tempFeature = totalData %>% group_by(subID) %>%summarize(feature = feature_index[1])
sprintf("Feature 1: %i; Feature 2: %i; Feature 3: %i",sum(tempFeature$feature==1),sum(tempFeature$feature==2),sum(tempFeature$feature==3))
## [1] "Feature 1: 6; Feature 2: 9; Feature 3: 10"

Add conditions

summarize = dplyr::summarize
completeFnames = unlist(completeFnames)
#trial conditions: different:0; same:1 (same as keys)
totalData$cond = NA;
totalData$cond[totalData$Fimg==totalData$Simg]=1;
totalData$cond[totalData$Fimg!=totalData$Simg]=0;


totalData$level_diff = abs(totalData$Simg-totalData$Fimg);


#Assign pair identity (ignore order)
totalData$pairIdentity = NA;

totalData$pairIdentity[totalData$cond==1&totalData$Fimg==1]=1
totalData$pairIdentity[totalData$cond==1&totalData$Fimg==2]=2
totalData$pairIdentity[totalData$cond==1&totalData$Fimg==3]=3
totalData$pairIdentity[totalData$cond==1&totalData$Fimg==4]=4
totalData$pairIdentity[totalData$cond==1&totalData$Fimg==5]=5
totalData$pairIdentity[totalData$cond==1&totalData$Fimg==6]=6
totalData$pairIdentity[totalData$cond==1&totalData$Fimg==7]=7

totalData$pairIdentity[totalData$Fimg==1&totalData$Simg==2]=12
totalData$pairIdentity[totalData$Fimg==2&totalData$Simg==1]=12

totalData$pairIdentity[totalData$Fimg==1&totalData$Simg==3]=13
totalData$pairIdentity[totalData$Fimg==3&totalData$Simg==1]=13

totalData$pairIdentity[totalData$Fimg==1&totalData$Simg==4]=14
totalData$pairIdentity[totalData$Fimg==4&totalData$Simg==1]=14

totalData$pairIdentity[totalData$Fimg==1&totalData$Simg==5]=15
totalData$pairIdentity[totalData$Fimg==5&totalData$Simg==1]=15

totalData$pairIdentity[totalData$Fimg==1&totalData$Simg==6]=16
totalData$pairIdentity[totalData$Fimg==6&totalData$Simg==1]=16

totalData$pairIdentity[totalData$Fimg==1&totalData$Simg==7]=17
totalData$pairIdentity[totalData$Fimg==7&totalData$Simg==1]=17

totalData$pairIdentity[totalData$Fimg==2&totalData$Simg==3]=23
totalData$pairIdentity[totalData$Fimg==3&totalData$Simg==2]=23

totalData$pairIdentity[totalData$Fimg==2&totalData$Simg==4]=24
totalData$pairIdentity[totalData$Fimg==4&totalData$Simg==2]=24

totalData$pairIdentity[totalData$Fimg==2&totalData$Simg==5]=25
totalData$pairIdentity[totalData$Fimg==5&totalData$Simg==2]=25

totalData$pairIdentity[totalData$Fimg==2&totalData$Simg==6]=26
totalData$pairIdentity[totalData$Fimg==6&totalData$Simg==2]=26

totalData$pairIdentity[totalData$Fimg==2&totalData$Simg==7]=27
totalData$pairIdentity[totalData$Fimg==7&totalData$Simg==2]=27

totalData$pairIdentity[totalData$Fimg==3&totalData$Simg==4]=34
totalData$pairIdentity[totalData$Fimg==4&totalData$Simg==3]=34

totalData$pairIdentity[totalData$Fimg==3&totalData$Simg==5]=35
totalData$pairIdentity[totalData$Fimg==5&totalData$Simg==3]=35

totalData$pairIdentity[totalData$Fimg==3&totalData$Simg==6]=36
totalData$pairIdentity[totalData$Fimg==6&totalData$Simg==3]=36

totalData$pairIdentity[totalData$Fimg==3&totalData$Simg==7]=37
totalData$pairIdentity[totalData$Fimg==7&totalData$Simg==3]=37

totalData$pairIdentity[totalData$Fimg==4&totalData$Simg==5]=45
totalData$pairIdentity[totalData$Fimg==5&totalData$Simg==4]=45

totalData$pairIdentity[totalData$Fimg==4&totalData$Simg==6]=46
totalData$pairIdentity[totalData$Fimg==6&totalData$Simg==4]=46

totalData$pairIdentity[totalData$Fimg==4&totalData$Simg==7]=47
totalData$pairIdentity[totalData$Fimg==7&totalData$Simg==4]=47

totalData$pairIdentity[totalData$Fimg==5&totalData$Simg==6]=56
totalData$pairIdentity[totalData$Fimg==6&totalData$Simg==5]=56

totalData$pairIdentity[totalData$Fimg==5&totalData$Simg==7]=57
totalData$pairIdentity[totalData$Fimg==7&totalData$Simg==5]=57

totalData$pairIdentity[totalData$Fimg==6&totalData$Simg==7]=67
totalData$pairIdentity[totalData$Fimg==7&totalData$Simg==6]=67

totalData$pairIdentity = as.factor(totalData$pairIdentity)
summarize = dplyr::summarize
#Times
TimesRT = totalData %>% group_by(subID,pairIdentity,feature_index,cond)%>%summarize(Frt = rt[1],Srt = rt[2], Trt = rt[3], Ftrial = trialNum[1],Strial = trialNum[2],Ttrial = trialNum[3])

TimesRT_long = gather(TimesRT, response_type, number_resp,Frt,Srt,Trt)
ggplot(subset(TimesRT_long, cond==1), aes(x = pairIdentity, y = number_resp, group = pairIdentity, color = as.factor(pairIdentity)))+
  geom_boxplot(fill = "white",lwd = 1)+
  geom_jitter(width=0.2,alpha = 0.5)+
  ylim(0,2500)+
  facet_wrap(response_type~feature_index)+
  labs(title="Same", x = "level", y = "RT")+
  plotformat
## Warning: Removed 16 rows containing missing values (geom_point).

ggplot(subset(TimesRT_long, cond==0), aes(x = pairIdentity, y = number_resp, group = pairIdentity, color = as.factor(pairIdentity)))+
  geom_boxplot(fill = "white",lwd = 1)+
  geom_jitter(width=0.2,alpha = 0.5)+
  facet_wrap(response_type~feature_index)+
  labs(title="Different", x = "Same level", y = "RT")+
  plotformat

TimesRTcorrect = totalData %>% group_by(subID,pairIdentity,feature_index,cond)%>%filter(accuracy==1) %>%summarize(Frt = rt[1],Srt = rt[2], Trt = rt[3], Ftrial = trialNum[1],Strial = trialNum[2],Ttrial = trialNum[3])

TimesRTcorrect_long = gather(TimesRTcorrect, response_type, number_resp,Frt,Srt,Trt)
ggplot(subset(TimesRTcorrect_long, cond==1), aes(x = pairIdentity, y = number_resp, group = pairIdentity, color = as.factor(pairIdentity)))+
  geom_boxplot(fill = "white",lwd = 1)+
  geom_jitter(width=0.2,alpha = 0.5)+
  facet_wrap(response_type~feature_index)+
  labs(title="Correct same", x = "Same level", y = "RT")+
  plotformat
## Warning: Removed 174 rows containing non-finite values (stat_boxplot).
## Warning: Removed 174 rows containing missing values (geom_point).

ggplot(subset(TimesRTcorrect_long, cond==0), aes(x = pairIdentity, y = number_resp, group = pairIdentity, color = as.factor(pairIdentity)))+
  geom_boxplot(fill = "white",lwd = 1)+
  geom_jitter(width=0.2,alpha = 0.5)+
  facet_wrap(response_type~feature_index,strip.position = 'bottom')+
  labs(title="Correct different", x = "Same level", y = "RT")+
  theme_facet()
## Warning: Removed 487 rows containing non-finite values (stat_boxplot).
## Warning: Removed 487 rows containing missing values (geom_point).

Behavior analysis

summarize = dplyr::summarize
basic = totalData %>% filter(keys>=0)%>% group_by(subID)%>% summarize(num_noresposnes = sum(keys==-1), num_same_resp = sum(keys==1), num_diff_resp = sum(keys==0), num_same_trials =sum(cond==1), num_diff_trials = sum(cond==0), 
                                                    hit = sum(keys==1&cond==1), 
                                                    fa= sum(keys==1&cond==0), 
                                                    cr = sum(keys==0&cond==0),
                                                    miss = sum(keys==0&cond==1),
                                                    HitRate =sum(keys==1&cond==1)/sum(cond==1), 
                                                    FARate = sum(keys==1&cond==0)/sum(cond==0), 
                                                    CRRate = sum(keys==0&cond==0)/sum(cond==0),
                                                    MissRate = sum(keys==0&cond==1)/sum(cond==1), 
                                                    d_p = qnorm(HitRate)-qnorm(FARate))
basic
## # A tibble: 25 x 15
##    subID num_noresposnes num_same_resp num_diff_resp num_same_trials
##    <int>           <int>         <int>         <int>           <int>
##  1     1               0            37            47              21
##  2     3               0            26            58              21
##  3     5               0            45            29              19
##  4     7               0            33            46              20
##  5     8               0            29            46              17
##  6    11               0            23            45              16
##  7    12               0            32            44              16
##  8    14               0            53            30              21
##  9    15               0            44            38              20
## 10    16               0            41            42              21
## # ... with 15 more rows, and 10 more variables: num_diff_trials <int>,
## #   hit <int>, fa <int>, cr <int>, miss <int>, HitRate <dbl>,
## #   FARate <dbl>, CRRate <dbl>, MissRate <dbl>, d_p <dbl>
#plotting
basic_longform = gather(basic, response_type, number_resp, HitRate,FARate,CRRate,MissRate)
head(basic_longform)
## # A tibble: 6 x 13
##   subID num_noresposnes num_same_resp num_diff_resp num_same_trials
##   <int>           <int>         <int>         <int>           <int>
## 1     1               0            37            47              21
## 2     3               0            26            58              21
## 3     5               0            45            29              19
## 4     7               0            33            46              20
## 5     8               0            29            46              17
## 6    11               0            23            45              16
## # ... with 8 more variables: num_diff_trials <int>, hit <int>, fa <int>,
## #   cr <int>, miss <int>, d_p <dbl>, response_type <chr>,
## #   number_resp <dbl>
ggplot(basic_longform, aes(x = response_type, y = number_resp, color = response_type))+
  geom_boxplot(fill = "white",lwd = 1)+
  geom_jitter(width=0.2,alpha = 0.5)+
  labs(title="Proportaion response type", x = "response type", y = "proportion")+
  plotformat

#d-p
ggplot(basic, aes(x = subID, y = d_p, color = as.factor(subID)))+
  geom_point(size=3)+
  labs(title="d prime", x = "subject", y = "d prime")+
  plotformat

remain_dp = basic$subID[basic$d_p>0.5]
sprintf("remove d prime lower than 0.5 %i",length(remain_dp))
## [1] "remove d prime lower than 0.5 7"
totalData = totalData %>%filter(subID%in%remain_dp)


#check feature number
tempFeature = totalData %>% group_by(subID) %>%summarize(feature = feature_index[1])
sprintf("Feature 1: %i; Feature 2: %i; Feature 3: %i",sum(tempFeature$feature==1),sum(tempFeature$feature==2),sum(tempFeature$feature==3))
## [1] "Feature 1: 1; Feature 2: 2; Feature 3: 4"
##########
basicFeature = totalData %>% filter(keys>=0)%>% group_by(subID,feature_index)%>% summarize(num_noresposnes = sum(keys==-1), num_same_resp = sum(keys==1), num_diff_resp = sum(keys==0), num_same_trials =sum(cond==1), num_diff_trials = sum(cond==0), 
                                                    hit = sum(keys==1&cond==1), 
                                                    fa= sum(keys==1&cond==0), 
                                                    cr = sum(keys==0&cond==0),
                                                    miss = sum(keys==0&cond==1),
                                                    HitRate =sum(keys==1&cond==1)/sum(cond==1), 
                                                    FARate = sum(keys==1&cond==0)/sum(cond==0), 
                                                    CRRate = sum(keys==0&cond==0)/sum(cond==0),
                                                    MissRate = sum(keys==0&cond==1)/sum(cond==1), 
                                                    d_p = qnorm(HitRate)-qnorm(FARate))
basicFeature_longform = gather(basicFeature, response_type, number_resp, HitRate,FARate,CRRate,MissRate)
head(basicFeature_longform)
## # A tibble: 6 x 14
## # Groups:   subID [6]
##   subID feature_index num_noresposnes num_same_resp num_diff_resp
##   <int>         <dbl>           <int>         <int>         <int>
## 1     1             2               0            37            47
## 2     8             3               0            29            46
## 3    15             3               0            44            38
## 4    21             1               0            43            41
## 5    23             3               0            24            60
## 6    29             3               0            19            65
## # ... with 9 more variables: num_same_trials <int>, num_diff_trials <int>,
## #   hit <int>, fa <int>, cr <int>, miss <int>, d_p <dbl>,
## #   response_type <chr>, number_resp <dbl>
ggplot(basicFeature_longform, aes(x = response_type, y = number_resp, color = response_type))+
  geom_boxplot(fill = "white",lwd = 1)+
  geom_jitter(width=0.2,alpha = 0.5)+
  facet_wrap(~feature_index)+
  labs(title="Proportaion response type by feature", x = "response type", y = "proportion")+
  plotformat

###########
basicLevel = totalData %>% filter(keys>=0)%>% group_by(subID,level_diff)%>% summarize(num_noresposnes = sum(keys==-1), num_same_resp = sum(keys==1), num_diff_resp = sum(keys==0), num_same_trials =sum(cond==1), num_diff_trials = sum(cond==0), 
                                                    hit = sum(keys==1&cond==1), 
                                                    fa= sum(keys==1&cond==0), 
                                                    cr = sum(keys==0&cond==0),
                                                    miss = sum(keys==0&cond==1),
                                                    HitRate =sum(keys==1&cond==1)/sum(cond==1), 
                                                    FARate = sum(keys==1&cond==0)/sum(cond==0), 
                                                    CRRate = sum(keys==0&cond==0)/sum(cond==0),
                                                    MissRate = sum(keys==0&cond==1)/sum(cond==1), 
                                                    d_p = qnorm(HitRate)-qnorm(FARate))
basicLevel_longform = gather(basicLevel, response_type, number_resp, HitRate,FARate,CRRate,MissRate)
head(basicLevel_longform)
## # A tibble: 6 x 14
## # Groups:   subID [1]
##   subID level_diff num_noresposnes num_same_resp num_diff_resp
##   <int>      <dbl>           <int>         <int>         <int>
## 1     1          0               0            13             8
## 2     1          1               0            10             8
## 3     1          2               0             7             8
## 4     1          3               0             3             9
## 5     1          4               0             2             7
## 6     1          5               0             1             5
## # ... with 9 more variables: num_same_trials <int>, num_diff_trials <int>,
## #   hit <int>, fa <int>, cr <int>, miss <int>, d_p <dbl>,
## #   response_type <chr>, number_resp <dbl>
ggplot(basicLevel_longform, aes(x = response_type, y = number_resp, color = response_type))+
  geom_boxplot(fill = "white",lwd = 1)+
  geom_jitter(width=0.2,alpha = 0.5)+
  facet_wrap(~level_diff,nrow = 1)+
  labs(title="Proportaion response type by difficulty level", x = "response type", y = "proportion")+
  theme_facet()
## Warning: Removed 98 rows containing non-finite values (stat_boxplot).
## Warning: Removed 98 rows containing missing values (geom_point).

###########
basicLevelFeature = totalData %>% filter(keys>=0)%>% group_by(subID,level_diff,feature_index)%>% summarize(num_noresposnes = sum(keys==-1), num_same_resp = sum(keys==1), num_diff_resp = sum(keys==0), num_same_trials =sum(cond==1), num_diff_trials = sum(cond==0), 
                                                    hit = sum(keys==1&cond==1), 
                                                    fa= sum(keys==1&cond==0), 
                                                    cr = sum(keys==0&cond==0),
                                                    miss = sum(keys==0&cond==1),
                                                    HitRate =sum(keys==1&cond==1)/sum(cond==1), 
                                                    FARate = sum(keys==1&cond==0)/sum(cond==0), 
                                                    CRRate = sum(keys==0&cond==0)/sum(cond==0),
                                                    MissRate = sum(keys==0&cond==1)/sum(cond==1), 
                                                    d_p = qnorm(HitRate)-qnorm(FARate))
basicLevelFeature_longform = gather(basicLevelFeature, response_type, number_resp, HitRate,FARate,CRRate,MissRate)
head(basicLevelFeature_longform)
## # A tibble: 6 x 15
## # Groups:   subID, level_diff [6]
##   subID level_diff feature_index num_noresposnes num_same_resp
##   <int>      <dbl>         <dbl>           <int>         <int>
## 1     1          0             2               0            13
## 2     1          1             2               0            10
## 3     1          2             2               0             7
## 4     1          3             2               0             3
## 5     1          4             2               0             2
## 6     1          5             2               0             1
## # ... with 10 more variables: num_diff_resp <int>, num_same_trials <int>,
## #   num_diff_trials <int>, hit <int>, fa <int>, cr <int>, miss <int>,
## #   d_p <dbl>, response_type <chr>, number_resp <dbl>
ggplot(basicLevelFeature_longform, aes(x = response_type, y = number_resp, color = response_type))+
  geom_boxplot(fill = "white",lwd = 1)+
  geom_jitter(width=0.2,alpha = 0.5)+
  facet_wrap(feature_index~level_diff,nrow = 3,strip.position = "bottom")+
  labs(title="Proportaion response type by difficulty level", x = "level diff", y = "proportion")+
  theme_facet()
## Warning: Removed 98 rows containing non-finite values (stat_boxplot).

## Warning: Removed 98 rows containing missing values (geom_point).

reaction time and difficulty levels

summarize = dplyr::summarize
responseData = totalData %>%filter(keys>=0,accuracy==1)
ggplot(responseData, aes(x = level_diff, y = rt, group = as.factor(level_diff), color = as.factor(level_diff)))+
   geom_boxplot(fill = "white",lwd = 1)+
  geom_jitter(width=0.2,alpha = 0.5)+
  facet_wrap(~feature_index)+
    ylim(0,2500)+
  labs(title="Reaction type by difficulty levels", x = "response type", y = "RT (ms)")+
  plotformat

responseData_firstHalf = totalData %>%filter(keys>=0,accuracy==1,trialNum<42)
ggplot(responseData_firstHalf, aes(x = level_diff, y = rt, group = as.factor(level_diff), color = as.factor(level_diff)))+
   geom_boxplot(fill = "white",lwd = 1)+
  geom_jitter(width=0.2,alpha = 0.5)+
  facet_wrap(~feature_index)+
    ylim(0,2500)+
  labs(title="Reaction type by difficulty levels -first", x = "response type", y = "RT (ms)")+
  plotformat

responseData_lastHalf = totalData %>%filter(keys>=0,accuracy==1,trialNum>42)
ggplot(responseData_lastHalf, aes(x = level_diff, y = rt, group = as.factor(level_diff), color = as.factor(level_diff)))+
   geom_boxplot(fill = "white",lwd = 1)+
  geom_jitter(width=0.2,alpha = 0.5)+
  facet_wrap(~feature_index)+
  ylim(0,2500)+
  labs(title="Reaction type by difficulty levels -last", x = "response type", y = "RT (ms)")+
  plotformat

#temp = responseData %>% group_by(subID, level_diff, feature_index) %>%summarise(mean_RT = mean(rt))
#ggplot(temp,aes(x = level_diff, y = mean_RT, group = level_diff))+
#  geom_boxplot(fill = "white",lwd = 1)+
#  geom_jitter(width=0.2,alpha = 0.5)+
#  facet_wrap(~feature_index)+
#  labs(title="Proportaion response type", x = "response type", y = "RT (ms)")+
#  plotformat

######
responseData = totalData %>%filter(keys>=0,accuracy==1,level_diff==0)
ggplot(responseData, aes(x = pairIdentity, y = rt, group = as.factor(pairIdentity), color = as.factor(pairIdentity)))+
   geom_boxplot(fill = "white",lwd = 1)+
  geom_jitter(width=0.2,alpha = 0.5)+
  facet_wrap(~feature_index)+
    ylim(0,2500)+
  labs(title="Reaction type for same pairs by levels", x = "levels", y = "RT (ms)")+
  plotformat

responseData = totalData %>%filter(keys>=0,accuracy==1,level_diff==1)
ggplot(responseData, aes(x = pairIdentity, y = rt, group = as.factor(pairIdentity), color = as.factor(pairIdentity)))+
   geom_boxplot(fill = "white",lwd = 1)+
  geom_jitter(width=0.2,alpha = 0.5)+
  facet_wrap(~feature_index)+
    ylim(0,2500)+
  labs(title="Reaction type for difference -- level 1", x = "levels", y = "RT (ms)")+
  plotformat

responseData = totalData %>%filter(keys>=0,accuracy==1,level_diff==2)
ggplot(responseData, aes(x = pairIdentity, y = rt, group = as.factor(pairIdentity), color = as.factor(pairIdentity)))+
   geom_boxplot(fill = "white",lwd = 1)+
  geom_jitter(width=0.2,alpha = 0.5)+
  facet_wrap(~feature_index)+
    ylim(0,2500)+
  labs(title="Reaction type for difference -- level 2", x = "levels", y = "RT (ms)")+
  plotformat

responseData = totalData %>%filter(keys>=0,accuracy==1,level_diff==3)
ggplot(responseData, aes(x = pairIdentity, y = rt, group = as.factor(pairIdentity), color = as.factor(pairIdentity)))+
   geom_boxplot(fill = "white",lwd = 1)+
  geom_jitter(width=0.2,alpha = 0.5)+
  facet_wrap(~feature_index)+
    ylim(0,2500)+
  labs(title="Reaction type for difference -- level 3", x = "levels", y = "RT (ms)")+
  plotformat

responseData = totalData %>%filter(keys>=0,accuracy==1,level_diff==4)
ggplot(responseData, aes(x = pairIdentity, y = rt, group = as.factor(pairIdentity), color = as.factor(pairIdentity)))+
   geom_boxplot(fill = "white",lwd = 1)+
  geom_jitter(width=0.2,alpha = 0.5)+
  facet_wrap(~feature_index)+
    ylim(0,2500)+
  labs(title="Reaction type for difference -- level 4", x = "levels", y = "RT (ms)")+
  plotformat

responseData = totalData %>%filter(keys>=0,accuracy==1,level_diff==5)
ggplot(responseData, aes(x = pairIdentity, y = rt, group = as.factor(pairIdentity), color = as.factor(pairIdentity)))+
   geom_boxplot(fill = "white",lwd = 1)+
  geom_jitter(width=0.2,alpha = 0.5)+
  facet_wrap(~feature_index)+
    ylim(0,2500)+
  labs(title="Reaction type for difference -- level 5", x = "levels", y = "RT (ms)")+
  plotformat

responseData = totalData %>%filter(keys>=0,accuracy==1,level_diff==6)
ggplot(responseData, aes(x = pairIdentity, y = rt, group = as.factor(pairIdentity), color = as.factor(pairIdentity)))+
   geom_boxplot(fill = "white",lwd = 1)+
  geom_jitter(width=0.2,alpha = 0.5)+
  facet_wrap(~feature_index)+
    ylim(0,2500)+
  labs(title="Reaction type for difference -- level 6", x = "levels", y = "RT (ms)")+
  plotformat

##accuracy and difficulty levels

accuracyData = totalData %>%filter(keys>=0)%>%group_by(subID,feature_index,level_diff)%>%summarize(meanAccuracy = sum(accuracy==1)/length(subID))
ggplot(accuracyData, aes(x = level_diff, y = meanAccuracy, group = as.factor(level_diff), color = as.factor(level_diff)))+
   geom_boxplot(fill = "white",lwd = 1)+
  geom_jitter(width=0.2,alpha = 0.5)+
  facet_wrap(~feature_index)+
  labs(title="Accuracy by difficulty levels", x = "difficulty level", y = "proportion correct")+
  plotformat

accuracy and pair

accuracyDataPairSame = totalData %>%filter(keys>=0,cond==1)%>%group_by(subID,feature_index,pairIdentity)%>%summarize(propAccuracy = sum(accuracy==1)/length(subID))

ggplot(accuracyDataPairSame, aes(x = pairIdentity, y = propAccuracy, group = as.factor(pairIdentity), color = as.factor(pairIdentity)))+
  geom_boxplot(fill = "white",lwd = 1)+
  geom_point(alpha = 0.5)+
  #geom_jitter(width=0.05,alpha = 0.5)+
  facet_wrap(~feature_index)+
  labs(title="Accuracy by same pairs", x = "difficulty level", y = "proportion correct")+
  plotformat

accuracyDataPairDiff = totalData %>%filter(keys>=0,cond==0)%>%group_by(subID,feature_index,pairIdentity)%>%summarize(propAccuracy = sum(accuracy==1)/length(subID))
ggplot(accuracyDataPairDiff, aes(x = as.factor(pairIdentity), y = propAccuracy, group = as.factor(pairIdentity), color = as.factor(pairIdentity)))+
  geom_boxplot(fill = "white",lwd = 1)+
  geom_point(alpha = 0.5)+
  #geom_jitter(width=0.2,alpha = 0.5)+
  facet_wrap(~feature_index)+
  labs(title="Accuracy by different pairs", x = "difficulty level", y = "proportion correct")+
  plotformat

accuracyDataPairDiff_level = totalData %>%filter(keys>=0,cond==0)%>%group_by(subID,feature_index,pairIdentity)%>%summarize(propAccuracy = sum(accuracy==1)/length(subID), level_diff = level_diff[1])

ggplot(filter(accuracyDataPairDiff_level,level_diff==1), aes(x = as.factor(pairIdentity), y = propAccuracy, group = as.factor(pairIdentity), color = as.factor(pairIdentity)))+
  geom_boxplot(fill = "white",lwd = 1)+
  geom_point(alpha = 0.5)+
  #geom_jitter(width=0.2,alpha = 0.5)+
  facet_wrap(~feature_index)+
  labs(title="Accuracy by different pairs --level 01", x = "difficulty level", y = "proportion correct")+
  plotformat

ggplot(filter(accuracyDataPairDiff_level,level_diff==2), aes(x = as.factor(pairIdentity), y = propAccuracy, group = as.factor(pairIdentity), color = as.factor(pairIdentity)))+
  geom_boxplot(fill = "white",lwd = 1)+
  geom_point(alpha = 0.5)+
  #geom_jitter(width=0.2,alpha = 0.5)+
  facet_wrap(~feature_index)+
  labs(title="Accuracy by different pairs --level 02", x = "difficulty level", y = "proportion correct")+
  plotformat

ggplot(filter(accuracyDataPairDiff_level,level_diff==3), aes(x = as.factor(pairIdentity), y = propAccuracy, group = as.factor(pairIdentity), color = as.factor(pairIdentity)))+
  geom_boxplot(fill = "white",lwd = 1)+
  geom_point(alpha = 0.5)+
  #geom_jitter(width=0.2,alpha = 0.5)+
  facet_wrap(~feature_index)+
  labs(title="Accuracy by different pairs --level 03", x = "difficulty level", y = "proportion correct")+
  plotformat

ggplot(filter(accuracyDataPairDiff_level,level_diff==4), aes(x = as.factor(pairIdentity), y = propAccuracy, group = as.factor(pairIdentity), color = as.factor(pairIdentity)))+
  geom_boxplot(fill = "white",lwd = 1)+
  geom_point(alpha = 0.5)+
  #geom_jitter(width=0.2,alpha = 0.5)+
  facet_wrap(~feature_index)+
  labs(title="Accuracy by different pairs --level 04", x = "difficulty level", y = "proportion correct")+
  plotformat

ggplot(filter(accuracyDataPairDiff_level,level_diff==5), aes(x = as.factor(pairIdentity), y = propAccuracy, group = as.factor(pairIdentity), color = as.factor(pairIdentity)))+
  geom_boxplot(fill = "white",lwd = 1)+
  geom_point(alpha = 0.5)+
  #geom_jitter(width=0.2,alpha = 0.5)+
  facet_wrap(~feature_index)+
  labs(title="Accuracy by different pairs --level 05", x = "difficulty level", y = "proportion correct")+
  plotformat

ggplot(filter(accuracyDataPairDiff_level,level_diff==6), aes(x = as.factor(pairIdentity), y = propAccuracy, group = as.factor(pairIdentity), color = as.factor(pairIdentity)))+
  geom_boxplot(fill = "white",lwd = 1)+
  geom_point(alpha = 0.5)+
  #geom_jitter(width=0.2,alpha = 0.5)+
  facet_wrap(~feature_index)+
  labs(title="Accuracy by different pairs --level 06", x = "difficulty level", y = "proportion correct")+
  plotformat